Figure 1
Different hint extension instructions.



Figure 2
Overview of the Processor operation with Hint processor



**New Hint Instruction to IL1 Entry** 

wr\_en hold 2 237

(BHT write

enable)

8 program instructions IFAR [48:58] **Read from Hint Instruction Cache** Read from BHT from IL1 cache bht\_bits 206 **Hint Instruction Generation Hint Instruction Execution** (Used for IL1 Cache Hit) (Used for IL1 Cache Miss) Hint Instr Reg 243 0 24 31 **Branch** mask ld\_bht op creation logic br\_mask bht\_bits 231 232 (bht curr\_bht reg index) 16 24 31 233 **BHT Hint** = ld\_bht op? **BHT Hint Write** Register **New BHT creation** 238 242 **Entry Register** logic BHT index hold 1 241 BHT index hold 2 new\_bht reg | 239 wr\_en hold 1 (write (write data) address)

Figure 2A The Hint Processor

Figure 2B New BHT creation logic 238

(write BHT entry)



(BHT index to read)

(BHT index to write)

Figure 3
Overview of the Instruction Fetch Unit with Hint Processor



Figure 4



**Branch Information Queue (BIQ)** 

Figure 5



## Figure 6



## Figure 7







B From Figure 8.

901

Fetch the IL1 cache line into "Eight Program Instructions" register, and the associated hint instructions in the Hint Instruction register.

Access the BHT entry indexed by the IFAR bits 48:58, and fetch its BHT prediction bits into the "Eight Predictions" register.

903

Use the IFAR bits 59:61 to locate "first instruction" in the "Eight Program Instructions" register. (Instructions before the "first instruction", if any, will be ignored).

904

Is there any branch instruction in the "Eight Program Instructions" register at or after the "first instruction"?

No 906

Yes 1 S

Designate a "fetch group" as the instructions from the "first instruction" to the end of the register. Set "Predicted\_IFAR" to the address of the next sequential instruction after the "fetch group".

In the hint processor, fill the BHT Hint register with the following: bits 0:4 with "ld\_bht\_op", bits 5:15 with IFAR bits 48:58, bits 16:23 with a 8-bit "branch mask" field containing a 1 in the positions where there is a branch and 0 in other positions, bits 24:31 with the 8-bit BHT prediction.

In the hint processor, store IFAR bits 48:58 in the BHT Hint Write Entry register

Store the content of the BHT Hint register in the Hint Instruction feld in the IL1 Cache at the location in the BHT Hint Write Entry register

911

Is any branch indicated in the "Eight Predictions" register to be an unconditional branch or a conditional branch predicted taken?

**↓Yes** 

912

Set "Predicted\_IFAR" to the target of the first of these branches and designates this branch as the "last instruction". No

914

Set "Predicted\_IFAR" to the address of the instruction next sequential to the last instruction fetched. Designate the last instruction in the "Eight Instructions" register as the "last instruction".

921

All instructions between the "first instruction" and the "last instruction" forms the "fetch group". For each branch in fetch group, obtain an invalid entry in the Branch Information Queue (BIQ), set its valid bit to 1 state and put:

the address of the branch in the "Address of the branch" field,

the branch target address in the "Predicted address" field if the branch is predicted taken or the sequential address in the "Predicted address" field if the branch is predicted not-taken,

if the branch is at position "n", store the n-th bit in the "Eight Predictions" register in the "BHT bit" field.

Place the branch in the branch issue queue for its subsequent execution.

926

Forward the fetch group to Instruction Decode Unit (IDU), see Figure 11.

Goto Figure 10, C

Figure 10



Figure 11

1102

1103

**Instruction Decode and Dispatch** 



Figure 12
Instruction issue and instruction execution



Figure 13
Execution in the Hint Processor for each IFAR cycle

